<template>
  <yk-layout-page>
    <yk-layout-page-item>
      <yk-table title="操作列" ref="selectionTable" :table="state.table"
        :btnPermissions="['operator-view-detail', 'operator-edit']" :columns="state.table.columns"
        @selection-change="selectionChange" :isShowPagination="false">
        <template #toolbar>
          <el-button size="default" type="primary" :disabled="state.ids.length < 1" @click="cancelSelect">取消选中</el-button>
          <el-button size="default" type="primary" @click="add">新增</el-button>
          <el-button size="default" type="danger" :disabled="state.ids.length < 1" @click="del">删除</el-button>
        </template>
      </yk-table>
    </yk-layout-page-item>
  </yk-layout-page>
</template>

<script setup lang="tsx">
import { reactive, ref } from "vue"
const viewDetail = val => {
  console.log("viewDetail", val)
}
const edit = val => {
  console.log("edit", val)
}
const nullify = val => {
  console.log("nullify", val)
}
// 获取ref
const selectionTable: any = (ref < HTMLElement) | (null > null)
let state = reactive({
  table: {
    firstColumn: { type: "selection", fixed: true },
    // 接口返回数据
    data: [
      {
        id: "1",
        date: "2019-09-25",
        date1: "2019-09-26",
        name: "张三",
        status: "2",
        address: "广东省广州市天河区"
      },
      {
        id: "2",
        date: "2019-09-26",
        date1: "2019-09-27",
        name: "张三1",
        status: "1",
        address: "广东省广州市天广东省广州市天河区2广东省广州市天河区2河区2"
      },
      {
        id: "3",
        date: "2019-09-26",
        date1: "2019-09-28",
        name: "张三1",
        status: "1",
        address: "广东省广州市天广东省广州市天河区2广东省广州市天河区2河区2"
      },
      {
        id: "4",
        date: "2019-09-26",
        date1: "2019-09-29",
        name: "张三1",
        status: "1",
        address: "广东省广州市天广东省广州市天河区2广东省广州市天河区2河区2"
      }
    ],
    // 表头数据
    columns: [
      { prop: "name", label: "姓名", width: "120" },
      { prop: "date", label: "日期", width: "180" },
      {
        prop: "status",
        label: "状态",
        width: "100"
      },
      { prop: "date1", label: "日期22", width: "180" },
      {
        prop: "address",
        label: "地址",
        width: "220"
      }
    ],
    // 表格内操作列
    operator: [
      {
        text: "查看",
        fun: viewDetail,
        hasPermi: "operator-view-detail",
        noshow: [{ key: "status", val: ["1"] }]
      },
      {
        text: "编辑",
        hasPermi: "operator-edit",
        fun: edit
      },
      {
        text: "作废",
        fun: nullify
      }
    ],
    // 操作列样式
    operatorConfig: {
      fixed: "right", // 固定列表右边（left则固定在左边）
      width: 200,
      label: "操作"
    }
  },
  ids: []
})
// 选择复选框
const selectionChange = (val: any) => {
  console.log("选择复选框", val)
  state.ids = val
}
// 取消选中
const cancelSelect = () => {
  console.log("取消选中", selectionTable.value)
  if (state.ids.length > 0) {
    console.log("取消选中222", selectionTable.value)
    selectionTable.value.clearSelection()
  }
}
// 新增按钮
const add = () => {
  console.log("add按钮")
  state.table.data.push({
    id: "3",
    date: "2019-09-26",
    date1: "2019-09-28",
    name: "push新增",
    status: "1",
    address: "广东省广州市天广东省广州市天河区2广东省广州市天河区2河区2"
  })
}
// 删除按钮
const del = () => {
  console.log("del按钮")
}
</script>
